--    Author    : MAYANTING
--    Name      : ADM.RPT_SUST_DLMG_PAST_PRO_ORG_LOAF.HQL
--    Functions : 表33：贷款发生额分机构类型分产品统计表
--    Purpose   :
--    Revisions or Comments
--    VER        DATE        AUTHOR           DESCRIPTION
--   ---------  ----------  ---------------  ------------------------------------
--    1.0        2018-06-11  MAYANTING           1.CREATE THE PROCEDURE
--
INSERT OVERWRITE TABLE ADM.RPT_SUST_DLMG_PAST_PRO_ORG_LOAF PARTITION (DATA_DATE = '20180331')
    -- 消费贷款
    SELECT
     AREA.AREA_CODE_4                                                                                            AS FIN_ORG_DIST
    ,FSE.CCY                                                                                                     AS CCY
    ,ORG.ORG_CODE                                                                                                AS ORG_TYP          -- 机构类型
    ,ORG.ORG_DSCR                                                                                                AS ORG_DESC         -- 机构类型描述
    ,CASE -- 普通贷款
          WHEN FSE.BUSINESS_TYPE IN ('F0211','F0212','F02131','F02132','F0219') THEN 'A1'
          WHEN FSE.BUSINESS_TYPE IN ('F02201','F02202','F02203') THEN 'A2'
          WHEN FSE.BUSINESS_TYPE='F023' THEN 'A3'
          -- 贸易融资
          WHEN FSE.BUSINESS_TYPE='F081' THEN 'B1'
          WHEN FSE.BUSINESS_TYPE='F082' THEN 'B2'
          -- 融资租赁
           WHEN FSE.BUSINESS_TYPE='F09' THEN 'C'
     END                                                                                                         AS BUSINESS_TYPE    -- 贷款产品类型
    ,CASE -- 普通贷款
          WHEN FSE.BUSINESS_TYPE IN ('F0211','F0212','F02131','F02132','F0219') THEN '消费贷款'
          WHEN FSE.BUSINESS_TYPE IN ('F02201','F02202','F02203') THEN '经营贷款'
          WHEN FSE.BUSINESS_TYPE='F023' THEN '固定资产贷款'
          -- 贸易融资
          WHEN FSE.BUSINESS_TYPE='F081' THEN '国际贸易融资'
          WHEN FSE.BUSINESS_TYPE='F082' THEN '国内贸易融资'
          -- 融资租赁
          WHEN FSE.BUSINESS_TYPE='F09' THEN '融资租赁'
     END                                                                                                         AS TYPE_DESC         -- 贷款产品类型描述
    ,SUM(COALESCE(FSE.OCCUR_AMOUNT,0))/100000000                                                                 AS OCCUR_AMOUNT     -- 贷款发生额
    ,SUM(COALESCE(FSE.AMOUNT_LM,0))/100000000                                                                    AS AMOUNT_LM        -- 发生额上期末
    ,SUM(COALESCE(FSE.AMOUNT_YS,0))/100000000                                                                    AS AMOUNT_YS        -- 当年累计发生额
    ,SUM(COALESCE(FSE.OCCUR_AMOUNT,0) - COALESCE(FSE.AMOUNT_YC,0))/100000000                                     AS AMOUNT_GROW      -- 同比增减
    ,SUM(COALESCE(FSE.WSUM_AMOUNT,0)                                                                             AS WSUM_AMOUNT      -- 发生额加权值
    ,SUM(COALESCE(FSE.WAMOUNT_LM,0))/100000000                                                                   AS WAMOUNT_LM       -- 发生额加权值上期末
    ,SUM(COALESCE(FSE.WAMOUNT_YS,0))/100000000                                                                   AS WAMOUNT_YS       -- 发生额加权值当年累计
    ,SUM(COALESCE(FSE.WAMOUNT_YC,0))/100000000                                                                   AS WAMOUNT_LC       -- 发生额加权值去年同期
    FROM (SELECT * FROM EDW.DS_LOAF_SUM WHERE BUSINESS_TYPE IN ('F0211','F0212','F02131','F02132','F0219','F02201','F02202','F02203','F023','F081','F082','F09')
          AND DATA_DATE='20180331') FSE
    -- 与地区表最细级关联
    LEFT JOIN (SELECT * FROM DIMENSION.T_ORG_AREA_RELATION WHERE AREA_LEVEL='3') REAL ON FSE.FIN_ORG_NO=REAL.ORG_ID AND '20180331' BETWEEN REAL.START_DATE AND REAL.END_DATE
    LEFT JOIN DIMENSION.T_AREA_CODE AREA ON REAL.AREA_CODE=AREA.AREA_CODE_4 AND '20180331' BETWEEN AREA.START_DATE AND AREA.END_DATE
    -- 关联机构表
    LEFT JOIN DIMENSION.T_ORG_REPORT ORG ON FSE.ORG_TYPE=ORG.ORG_CODE
    GROUP BY  AREA.AREA_CODE_4
             ,FSE.CCY
             ,ORG.ORG_CODE
             ,ORG.ORG_DSCR
             ,CASE -- 普通贷款
                   WHEN FSE.BUSINESS_TYPE IN ('F0211','F0212','F02131','F02132','F0219') THEN 'A1'
                   WHEN FSE.BUSINESS_TYPE IN ('F02201','F02202','F02203') THEN 'A2'
                   WHEN FSE.BUSINESS_TYPE='F023' THEN 'A3'
                   -- 贸易融资
                   WHEN FSE.BUSINESS_TYPE='F081' THEN 'B1'
                   WHEN FSE.BUSINESS_TYPE='F082' THEN 'B2'
                   -- 融资租赁
                    WHEN FSE.BUSINESS_TYPE='F09' THEN 'C'
              END
             ,CASE -- 普通贷款
                   WHEN FSE.BUSINESS_TYPE IN ('F0211','F0212','F02131','F02132','F0219') THEN '消费贷款'
                   WHEN FSE.BUSINESS_TYPE IN ('F02201','F02202','F02203') THEN '经营贷款'
                   WHEN FSE.BUSINESS_TYPE='F023' THEN '固定资产贷款'
                   -- 贸易融资
                   WHEN FSE.BUSINESS_TYPE='F081' THEN '国际贸易融资'
                   WHEN FSE.BUSINESS_TYPE='F082' THEN '国内贸易融资'
                   -- 融资租赁
                   WHEN FSE.BUSINESS_TYPE='F09' THEN '融资租赁'
              END

    UNION ALL

    -- 合计
    SELECT
     AREA.AREA_CODE_4                                                                                            AS FIN_ORG_DIST
    ,FSE.CCY                                                                                                     AS CCY
    ,ORG.ORG_CODE                                                                                                AS ORG_TYP          -- 机构类型
    ,ORG.ORG_DSCR                                                                                                AS ORG_DESC         -- 机构类型描述
    ,'Z'                                                                                                         AS BUSINESS_TYPE    -- 贷款产品类型
    ,'合计'                                                                                                      AS TYPE_DESC        -- 贷款产品类型描述
    ,SUM(COALESCE(FSE.OCCUR_AMOUNT,0))/100000000                                                                 AS OCCUR_AMOUNT     -- 贷款发生额
    ,SUM(COALESCE(FSE.AMOUNT_LM,0))/100000000                                                                    AS AMOUNT_LM        -- 发生额上期末
    ,SUM(COALESCE(FSE.AMOUNT_YS,0))/100000000                                                                    AS AMOUNT_YS        -- 当年累计发生额
    ,SUM(COALESCE(FSE.OCCUR_AMOUNT,0) - COALESCE(FSE.AMOUNT_YC,0))/100000000                                     AS AMOUNT_GROW      -- 同比增减
    ,SUM(COALESCE(FSE.WSUM_AMOUNT,0)                                                                             AS WSUM_AMOUNT      -- 发生额加权值
    ,SUM(COALESCE(FSE.WAMOUNT_LM,0))/100000000                                                                   AS WAMOUNT_LM       -- 发生额加权值上期末
    ,SUM(COALESCE(FSE.WAMOUNT_YS,0))/100000000                                                                   AS WAMOUNT_YS       -- 发生额加权值当年累计
    ,SUM(COALESCE(FSE.WAMOUNT_YC,0))/100000000                                                                   AS WAMOUNT_LC       -- 发生额加权值去年同期
    FROM (SELECT * FROM EDW.DS_LOAF_SUM WHERE DATA_DATE='20180331') FSE
    -- 与地区表最细级关联
    LEFT JOIN (SELECT * FROM DIMENSION.T_ORG_AREA_RELATION WHERE AREA_LEVEL='3') REAL ON FSE.FIN_ORG_NO=REAL.ORG_ID AND '20180331' BETWEEN REAL.START_DATE AND REAL.END_DATE
    LEFT JOIN DIMENSION.T_AREA_CODE AREA ON REAL.AREA_CODE=AREA.AREA_CODE_4 AND '20180331' BETWEEN AREA.START_DATE AND AREA.END_DATE
    -- 关联机构表
    LEFT JOIN DIMENSION.T_ORG_REPORT ORG ON FSE.ORG_TYPE=ORG.ORG_CODE
    GROUP BY  AREA.AREA_CODE_4
             ,FSE.CCY
             ,ORG.ORG_CODE
             ,ORG.ORG_DSCR;